/* 1 用户上划页面 滚动条触底 开始加载下一页数据
 1 找到滚动条触底事件  微信开发文档
  2判断是否有下一页
       1获取总页数
       2获取当前页数
       3.判断当前 页数 是否大于 总页数（总条数/页数）
  3 假如没有下一页数据 弹出提示
  4假如存在下一页数据 加载下一页数据 
       1当前的页码++
       2重新发送请求
       3数据请求回来 要对data中的数据拼接 而不是全部替换
*/
/*
  1 触发下拉刷新事件 需要在页面的json文件中开启一个配置项
  2重置 数据 数组
  3重置页码 设置为1
*/
import { request } from "../../request/request.js";
Page({

  /**
   * 页面的初始数据
   */
  data: {
    tabs: [
      {
        id: 0,
        value: "综合",
        isActive: true
      },
      {
        id: 1,
        value: "销量",
        isActive: false
      },
      {
        id: 3,
        value: "价格",
        isActive: false
      }
    ],
    goodsList: [],
  },


  // 接收要的参数
  QueryParams: {
    query: "",
    cid: "",
    pagenum: 1,
    pagesize: 10
  },

  // 总页数
  totalpages:1,

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    this.QueryParams.cid = options.cid;
    this.getComputedStyle()
  },

  // 获取商品列表的数据
  getComputedStyle() {
    request({ url: 'goods/search', data: this.QueryParams }).then(res => {
      const total=res.data.message.total
      this.totalpages=Math.ceil(total/this.QueryParams.pagesize)
      console.log(this.totalpages);
      this.setData({
        // 拼接数组 旧数据 +下一页数据
        goodsList:[...this.data.goodsList,... res.data.message.goods]
      })
      console.log(this.data.goodsList);
    })


    // 4关闭下拉刷新的窗口
    wx.stopPullDownRefresh();
  },


  // 标题的点击事件 子传父事件
  hendleTabsItemChang(e) {
    // 1 获取被点击的标题索引
    const { index } = e.detail;
    console.log({ index });

    let { tabs } = this.data;
    // 2 修改原数组
    // tabs.forEach((v,i)=>i===index?v.isActive=true:v.isActive=false)
    tabs.forEach((v, i) => i === index ? v.isActive = true : v.isActive = false)
    console.log(this.data.tabs);
    // 赋值
    this.setData({
      tabs
    })

  },



  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {
      // 重置数组（原先有拼接新数据）
      this.setData({
        goodsList:[]
      })
  
      // 2重置页码
      this.QueryParams.pagenum=1;
      // 3发送请求
      this.getComputedStyle() 
  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {
    console.log("触底");
    if(this.QueryParams.pagenum >=this.totalpages){
      wx.showToast({
        title: '没有下一页数据了',
      });
    }else{
      this.QueryParams.pagenum++;
      this.getComputedStyle()
    }
  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {
  
  }
})